| Página Principal / M                       | is cursos / ArqComp21 / Parcial 1 / Parcial 1                                                                                      |
|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
|                                            |                                                                                                                                    |
| Comenzado el                               | Friday, 24 de September de 2021, 09:00                                                                                             |
| Estado                                     | Finalizado                                                                                                                         |
| Finalizado en                              | Friday, 24 de September de 2021, 11:26                                                                                             |
| Tiempo<br>empleado                         | 2 horas 25 minutos                                                                                                                 |
| Calificación                               | <b>8,60</b> de 10,00 ( <b>86</b> %)                                                                                                |
| Pregunta <b>1</b>                          |                                                                                                                                    |
| Correcta                                   |                                                                                                                                    |
| Puntúa 0,25 sobre 0,25                     |                                                                                                                                    |
| Si no asigna una va<br>que considere corre | ariable en todas las ejecuciones posibles de una instrucción always_comb, entonces (seleccionar <b>todas</b> las respuestas ectas) |
| a. Se infiere ur                           | latch 🗸                                                                                                                            |
| b. Se infiere ur                           | na condición no importa (don't care).                                                                                              |
| c. Se interpreta                           | a un always_ff en lugar del always_comb                                                                                            |
| d. La variable s                           | se pone a cero                                                                                                                     |

La respuesta correcta es: Se infiere un latch

Pregunta **2**Parcialmente correcta
Puntúa 1,07 sobre 1,25

A continuación se describe en SystemVerilog el módulo "sequential". Completar los cuadros vacíos para su correcta interpretación. En todos los casos completar en minúsculas, sin espacios y usando los caracteres que considere necesarios.

```
module sequential #(
 parameter
✓ N=8)
(
 output

✓ logic [N-1:0] y, z,

 input

✓ logic clk, reset);
 always

✓ @(posedge clk, posedge reset)
 begin
  if (reset) begin
    y <= '0;
    z <= '0;
 end if
  else begin
    y <= '1;
    z <= '1;
end
 endmodule
```

```
Pregunta 3
Parcialmente correcta
Puntúa 1,00 sobre 1,25
 Dado el siguiente módulo en SystemVerilog:
 module my_unit(input logic clk, x,
                    output logic y1, y2);
    logic w;
    assign w = x|(\sim y1);
    always_ff@(posedge clk)
      y2 <= w;
    always_ff@(negedge clk)
      y1 <=y2;
 endmodule
 Responder:
 a) Las señales (y1 e y2) se actualizan de forma:
  Asíncrona
  ONinguna de las opciones
  Ouna síncrona y la otra asíncrona

Síncrona

✓

    La respuesta correcta es: Síncrona
 b) La señal w se actualiza cuando:
  Ocambia el valor de y2
  O El clock pasa de "0" a "1"

■El clock pasa de "1" a "0"

x

  Ninguna de las opciones
    La respuesta correcta es: Ninguna de las opciones
 c) La señal y1 se actualiza cuando:
  OEI clock pasa de "0" a "1"

○El clock pasa de "1" a "0"

✓
  Ocambia el valor de y2
  ONinguna de las opciones
    La respuesta correcta es: El clock pasa de "1" a "0"
 d) Si al iniciar una simulación las señales x, clk e y1 están en "0", qué valor tendrán y1 e y2 después del primer flanco negativo del clock?
 (Responder sólo con caracteres: 0, 1 ó x, la cantidad necesaria. Sólo el número en binario, NO en formato SystemVerilog)
 y1 =
   1
 y2 =
```

| /21/21, 11.25 AM                             | rarcial 1. Nevision del Intento                                                                                                                                                                             |  |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Pregunta <b>4</b>                            |                                                                                                                                                                                                             |  |
| Correcta                                     |                                                                                                                                                                                                             |  |
| Puntúa 0,50 sobre 0,50                       |                                                                                                                                                                                                             |  |
|                                              | nem) del procesador de un ciclo desarrollado en los prácticos 1 y 2 posee 64 palabras, direccionadas por                                                                                                    |  |
|                                              | e encuentran conectados a los bits [72] de la dirección de 64 bits "IM_address".                                                                                                                            |  |
|                                              | dicha memoria de instrucciones. Para esto, se debe agregar un bit en la entrada de address del módulo, its de la dirección completa "IM_addr" debería conectarse la entrada de #imem luego de realizar esta |  |
| a. IM_address[71]                            |                                                                                                                                                                                                             |  |
| o b. Ninguna de las opciones                 |                                                                                                                                                                                                             |  |
| c. IM_address[81]                            |                                                                                                                                                                                                             |  |
| od. IM_address[82]                           |                                                                                                                                                                                                             |  |
| e. IM_address[72]                            |                                                                                                                                                                                                             |  |
| La respuesta correcta es: IM_ado             | dress[82]                                                                                                                                                                                                   |  |
| Pregunta <b>5</b>                            |                                                                                                                                                                                                             |  |
| Correcta                                     |                                                                                                                                                                                                             |  |
| Puntúa 0,50 sobre 0,50                       |                                                                                                                                                                                                             |  |
| Agregar la instrucción ORRI al m             | nicroprocesador de un ciclo desarrollado en los prácticos 1 y 2 requiere                                                                                                                                    |  |
| a. Incrementar el tamaño (er                 | n bits) de las instrucciones                                                                                                                                                                                |  |
| <ul><li>b. Todas las opciones</li></ul>      |                                                                                                                                                                                                             |  |
| <ul><li>c. Ninguna de las opciones</li></ul> |                                                                                                                                                                                                             |  |
| od. Incrementar el tamaño (er                | n bits) del puerto de entrada "a" de la ALU                                                                                                                                                                 |  |
| e. Incrementar la cantidad de                | e registros                                                                                                                                                                                                 |  |
| f. Incrementar el tamaño (en                 | bits) del program counter (PC)                                                                                                                                                                              |  |
|                                              |                                                                                                                                                                                                             |  |

La respuesta correcta es: Ninguna de las opciones

Pregunta **6**Correcta
Puntúa 1,25 sobre 1,25

Considerando el siguiente segmento de código:

1>> add x2, x5, x3

2>> eor x4, x5, x2

3>> Idur x5, [x2, #0]

## Responder:

a) ¿Cual de las siguientes dependencias son correctas? (marcar todas las opciones correctas)

[Tipo de dependencia, Instrucciones, Registro (en caso de ser necesario)]

- □ Datos, 1-3, X2
   ✓
- Datos, 2-3, X2
- Datos, 1-2, X5
- Control, 3
- Datos, 2-3, X5
- Estructural, 1-3

La respuesta correcta es:

- Datos, 1-2, X2
- Datos, 1-3, X2

b) Llenar la siguiente tabla con el orden de ejecución de las instrucciones utilizando un procesador con stall.

En la columna Instrucción indicar el número de instrucción ejecutada o una S en caso de ejecutarse un stall. En las columnas C1..C11 indicar la etapa de ejecución (Fetch: F, Decode: D, Execute: E, Memory: M, Writeback: W). En las celdas no utilizadas colocar un guion medio (-). Ejemplo de como llenar la tabla:



| # Instrucción |   |   |   |   |   |   |   |   |   | C10 |   |
|---------------|---|---|---|---|---|---|---|---|---|-----|---|
| 3             | - | - | - | F | D | E | M | W | - | -   | - |
| S             | - | - | - | - | F | D | S | S | S | -   | - |



| S      | - | - | F<br>• | D 🕶    | S 🗸 | S 🗸 | S 🗸 | -   | - | - | - |
|--------|---|---|--------|--------|-----|-----|-----|-----|---|---|---|
| 2      | - | - | -      | F<br>• | D • | E 🗸 | M • | W   | - | - | - |
| 3      | - | - | -      | -      | F   | D • | E 🕶 | M • | W | - | - |
| -<br>• | - | - | -      | -      | -   | -   | -   | -   | - | - | - |
| -      | - | - | -      | -      | -   | -   | -   | -   | - | - | - |

El número de filas de la tabla puede ser mayor a las que realmente requiera, llenar las filas no utilizadas con guiones medios (-).

Pregunta **7**Parcialmente correcta
Puntúa 1,45 sobre 1,50

Considerando el siguiente segmento de código:

1>> e1: LDUR X1, [X0, #0]

2>> ADDI X2, X1, #100

3>> STUR X1, [X0, #-8]

4>> SUBI X0, X0, #16

5>> CBZ X0, e2

6>> B e1

7>> e2: ADD X0, X3, X4

8>> SUB X3, X0, X5

## Responder:

1) ¿Cual de las siguientes dependencias son correctas? (marcar todas las opciones correctas)

[Tipo de dependencia, Instrucciones, Registro (en caso de ser necesario)]

- Control, 5,1, X0
- Datos, 3,4, X0
- Datos, 2,3, X1
- Estructural, 3,4
- ☑Control, 5☑
- Datos Condicional 4,3, X0
- □ Datos, 4,5, X0
   ☑

## La respuesta correcta es:

- Datos, 1,3, X1
- Control, 5
- Datos, 4,5, X0
- · Datos Condicional 4,3, X0
- 2) El código es ejecutado por un procesador con *forwarding stall y* que ante un salto condicional asume Always not taken. Además, el registro X0 contiene el valor X0 = 16. A partir del orden de ejecución, responder las siguientes preguntas:
- a) ¿Cual de los siguientes forwarding son necesarios en la ejecución del código?(marcar todas las opciones correctas)

[Instrucción inicial, instrucción final; Etapa inicial, etapa final; Registro involucrado]

- 1,3; Memory, Execute; X0
- 1,2; Memory, Execute; X1
- √4,5;Execute,Execute;X0
  ✓
- 3,4; Execute, Execute; X0

## La respuesta correcta es:

- 1,2; Memory, Execute; X1
- 4,5;Execute,Execute;X0
- 7,8; Execute, Execute; X0

| b) ¿Cuantos forwarding en to                | otal se necesitaron?   | ?             |               |              |              |              |                           |            |
|---------------------------------------------|------------------------|---------------|---------------|--------------|--------------|--------------|---------------------------|------------|
| 3                                           |                        |               |               |              |              |              |                           |            |
| <b>✓</b>                                    |                        |               |               |              |              |              |                           |            |
| c) ¿Cuantos ciclos de clock :               | se pierden por stalls  | s?            |               |              |              |              |                           |            |
| d) ¿Cuantos ciclos de clock                 | co niordon nor fluck   | on casa i     | ano no coa    | nococario    | roalizar flu | ich do inetr | ruccionas raspandar (     | 1)3        |
| 3                                           | se pierden por ilusi   | r (en caso (  | que no sea    | necesano     | realizar ilu | isn de instr | acciones, responder d     | <i>)</i> ? |
| e) ¿Cuantos ciclos de clock                 | se necesitaron para    | a ejecutar to | odo el códi   | go?          |              |              |                           |            |
| f) ¿En que etapa se encuentra               | la instrucción 7 en el | clock 10?     |               |              |              |              |                           |            |
| ● Fetch ✔                                   | Execute                | Ow            | riteback      | ONir         | iguna es co  | rrecta       | ODecode                   |            |
| La respuesta correcta es: F                 | etch                   |               |               |              |              |              |                           |            |
| Pregunta <b>8</b>                           |                        |               |               |              |              |              |                           |            |
| Correcta                                    |                        |               |               |              |              |              |                           |            |
| Puntúa 1,25 sobre 1,25                      |                        |               |               |              |              |              |                           |            |
| Asumiendo que las etapas indi               | viduales del pipeline  | de un proce   | esador tiene  | n las siguie | ntes latenci | as:          | _                         |            |
|                                             |                        | IF            | ID            | EX           | MEM          | WB           |                           |            |
|                                             | Latencia por etapa     | 180 ns        | 50 ns         | 150 ns       | 200 ns       | 100 ns       |                           |            |
| a) ¿Cuál es la latencia de una              | instrucción y el meno  | or periodo po | osible de rel | oj para un n | nicroproces  | ador sin pip | peline?                   |            |
| Latencia:                                   |                        |               |               |              |              |              |                           |            |
| 680                                         |                        |               |               |              |              |              |                           |            |
| ✓ ns                                        |                        |               |               |              |              |              |                           |            |
| Periodo de reloj:                           |                        |               |               |              |              |              |                           |            |
| 680                                         |                        |               |               |              |              |              |                           |            |
| ✓ ns                                        |                        |               |               |              |              |              |                           |            |
| b) ¿Cuál es la latencia de una              | instrucción y el meno  | or periodo po | osible de rel | oj para un n | nicroproces  | ador con pi  | peline?                   |            |
| Latencia:                                   |                        |               |               |              |              |              |                           |            |
| 1000                                        |                        |               |               |              |              |              |                           |            |
| ✓ ns                                        |                        |               |               |              |              |              |                           |            |
| Periodo de reloj:                           |                        |               |               |              |              |              |                           |            |
| 200                                         |                        |               |               |              |              |              |                           |            |
| ✓ ns                                        |                        |               |               |              |              |              |                           |            |
| c) ¿Cuántas instrucciones se d<br>pipeline? | leben ejecutar seguid  | las para que  | e el rendimie | ento del mic | roprocesad   | or con pipel | line sea mejor que el mis | smo sir    |
| 2                                           |                        |               |               |              |              |              |                           |            |

Pregunta **9**Parcialmente correcta
Puntúa 0,83 sobre 1,25

Considere que la siguiente sección de código está presente en el vector de excepciones de un microprocesador LEGv8, similar al implementado en el Práctico 3.

| 1> | exc_vector: | MRS  | Х9,         | S2_0_C2_C0_0 |
|----|-------------|------|-------------|--------------|
| 2> |             | CMP  | Χ9,         | 0x01         |
| 3> |             | B.E  | Q tra       | ар           |
| 4> |             | MRS  | <b>X</b> 9, | S2_0_C0_C0_0 |
| 5> |             | BR 2 | <b>X</b> 9  |              |
| 6> | trap:       | B ti | rap         |              |

Seleccionar las respuestas correctas de las siguientes afirmaciones:

- 1. "Ante la ocurrencia de una excepción, el código queda atrapado en un lazo infinito..."
- ... solo si se trata de una excepción de OpCode invalido.
- ... siempre, independientemente del tipo de excepción.
- Ninguna de las anteriores es correcta

La respuesta correcta es: ... solo si se trata de una excepción por interrupción externa.

- 2. "Si suponemos que la instrucción de la línea 2> (CMP) está corrompida en memoria en forma permanente (generando un OpCode invalido), considerando la implementación particular de nuestro procesador, el mismo...":
- O... no realiza ninguna acción porque ya está en el vector de excepciones y retorna normalmente.
- ... queda atrapado en el bucle infinito del label "trap".
- O... genera un comportamiento impredecible, porque este caso no está contemplado en la lógica de excepciones.
- ■Ninguno de los anteriores es correcta

  ✓

La respuesta correcta es: Ninguno de los anteriores es correcta

- 3. "Este código retorna a la dirección de memoria donde se encuentra ...":
- ... la instrucción que generó la excepción por OpCode invalido
- ... la siguiente instrucción que debía ejecutarse de no haberse producido la excepción por OpCode invalido.
- ... la instrucción que estaba en ejecución al generarse una excepción por interrupción externa.
- … la siguiente instrucción que debía ejecutarse de no haberse producido una excepción por interrupción externa. \*\*

La respuesta correcta es: ... la siguiente instrucción que debía ejecutarse de no haberse producido la excepción por OpCode invalido.

| Pregunta 10                                                                                                                            |   |
|----------------------------------------------------------------------------------------------------------------------------------------|---|
| Correcta                                                                                                                               |   |
| Puntúa 0,50 sobre 0,50                                                                                                                 |   |
|                                                                                                                                        |   |
| En nuestro procesador LEGv8, la señal de <b>ExtlAck</b> , que indica que una interrupción externa ha sido atendida, se mantiene en "1" |   |
| a mientras la señal ExtIRQ este en "0"                                                                                                 |   |
|                                                                                                                                        | ~ |
| ○ c durante 2 ciclos de CLK                                                                                                            |   |
| ○ d mientras se ejecuta la ISR                                                                                                         |   |
|                                                                                                                                        |   |
| La respueste sorreste sor, divisinte un pala siale de CUV                                                                              |   |
| La respuesta correcta es: durante un solo ciclo de CLK                                                                                 |   |
|                                                                                                                                        |   |
| Pregunta 11                                                                                                                            |   |
| Incorrecta                                                                                                                             |   |
| Puntúa 0,00 sobre 0,50                                                                                                                 |   |
|                                                                                                                                        |   |
| Si se quisiera determinar la dirección de un OpCode invalido, es necesario utilizar:                                                   |   |
| Si se quisiera determinar la dirección de un opcode invalido, es necesario dilizar.                                                    |   |
|                                                                                                                                        |   |
| <ul><li>a. Ninguno es correcto</li></ul>                                                                                               | × |
| ○ b. Solo el registro ELR                                                                                                              |   |
| ○ c. Solo el registro ERR                                                                                                              |   |
| ○ d. Los registros ERR y ELR                                                                                                           |   |
| ○ e. Los registros ESR y el ELR                                                                                                        |   |
|                                                                                                                                        |   |
|                                                                                                                                        |   |
| La respuesta correcta es: Los registros ESR y el ELR                                                                                   |   |
|                                                                                                                                        |   |
|                                                                                                                                        |   |
| ■ Why Raspberry Pi isn't vulnerable to Spectre or Meltdown                                                                             |   |
| Ir a                                                                                                                                   |   |
|                                                                                                                                        |   |

Parcial 2 ►